<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="jq/jquery1.9/jquery-1.9.0.js"></script>
    <script>
        $(function () {
            $("input:eq(0)").click(function () {
                console.log($("div:visible").length);
                $("div:visible").css("background", "yellow");
            });
            $("input:eq(1)").click(function () {
               /*  
                3.1版本之前
                他们的CSS display值是none。 
                他们是type="hidden"的表单元素。 
                它们的宽度和高度都显式设置为0。 
                一个祖先元素是隐藏的，因此该元素是不会在页面上显示。  
                不包含visiblity:hidden的元素
                */

                console.log($("div:hidden").length);
                $("div:hidden").css("background", "yellow");
            });

            $("input:eq(2)").click(function () {
                console.log($("body :hidden").length);
                
            });
        });
    </script>
</head>

<body>
    <input type="button" value="选择所有可见的div">
    <input type="button" value="选择所有隐藏的div">
    <input type="button" value="选择所有隐藏的元素">
    <div>可见div1</div>
    <div>可见div2</div>
    <div style="display:none;">不可见div</div>
    <div style="width:0px;height:0px;"></div>
    <div style="display:none;">
        <div>sasas</div>
    </div>
    <input type="hidden">
    <p style="visibility:hidden;">ssdsd</p>
</body>

</html>